

International Journal of Advanced Research in Computer and Communication Engineering Vol. 2, Issue 8, August 2013

# A Novel approach of identifying uninitialized register in SOC designs

Kamal prakash pandey<sup>1</sup>, Rakesh Kumar Singh<sup>2</sup>, Surendra Kumar Tadi<sup>3</sup>, Anil Kumar<sup>4</sup>

Associate Professor Department of Electronics And Communication Engineering SIET, Allahabad, India<sup>1,2</sup>

Research Scholar Electronics And Communication Engineering SIET, Allahabad, India<sup>3</sup>

Assistant Professor Department of Electronics and Communication Engineering, SHIATS-DU, Allahabad, India<sup>4</sup>

Abstract: As we know that today's'SoC designs comprise of IP blocks from different design team and vendors. Integrating and verifying them is a challenge for design teams. Verification happens mainly in two stages RTL and Gate level simulation. One of the key challenges in gate level simulation of a ASIC/SoC is X (unknown) propagation debug. X propagation happens due to many reasons such as uninitialized memory, timing violations and due to non-resettable flops. X propagation due to non resettable flops are very difficult to debug and consumes enormous time, challenge further increases due to presence of hundreds/thousands of such non resettable flops which needs to be traced separately for every X propagation, To avoid these X propagation, such flops should be initialized with random value 0 or 1 in the beginning (at 0 time) to mimic silicon behavior but the problem is list of such non resettable flops is not available to the soc team and there are no efficient & reliable techniques present to identify such flops. The proposed paper explains a methodology which can generate a list of non resettable flops required to avoid 'X' propagation in gate simulation. This uses formal tools and gate level VCD of the physical design.

Keywords: Non resettable flop, Gate level Simulation, Uninitialized register

### I. INTRODUCTION

Gate level simulation now a day is almost mandatory for un-initialized memory, uninitialized flop, timing violation every complex SoC. As design complexity, number of etc.. With multimillion gates design and multiple clock asynchronous clock domain and size of the design domains, significant amount of time is spent in debugging increases, gate level verification becomes very challenging and time consuming task. Basic question arises in minds of many "why do we need gate level simulation when STA (static timing analysis) and formal verification is done". There are multiple reasons for this.

STA may set false and multi cycle paths where • they don't belong – wrong understanding of the design may lead to wrong false path definition.

Validate asynchronous flop to flop paths which STA doesn't cover.

Validate constrains defined during formal verification while DFT logic is inserted after synthesis.

BCS/WCS Timing simulation with back annotated SDF to validate dynamic switching.

ATE tester pattern generation from • SDF simulation.

Identify any faulty initial condition of the flop -X/Z, RTL simulation is normally optimistic and may initialize a flop with 0 or 1 which may not match with silicon behavior while gate level simulation is quite close to silicon.

Gate level simulation is verified with ZD (zero delay) to validate if the design has come out of reset, scan insertion is proper. Fully SDF back annotated gate level simulation is done to validate CDC (clock domain crossing), STA the design and initialization issues. timings and dynamic switching. SDF based simulation may also be used for ATE pattern generation.

One of the key challenges of gate level simulation is identification of X propagation which may happen due to

Copyright to IJARCCE

source of X and fixing the X propagation.

### **II. EXISTING APPROACHES**

Gate level simulation is a very painful and time consuming task. Traditionally it is done using VCS simulator or any other industry standard simulator tool. Most of the time is spent in debugging X (unknown) propagation in the simulation. This debug of tracing X is manual effort which is dependent on person's experience and design knowledge. Practically it is not possible to run 100% test cases at gate level. So a subset of total verification suite is run on gate level. This limits number of issues that can be un-covered.

There are several causes for X propagation in GLS. Most complex one to debug being non-resettable or un-initialized flops. This paper presents an innovative flow of finding all non-resettable flops which causes X propagation if not initialized. This uses gate level VCD along with cadence formal verification tool, LEC verify. VCD is a dump in standard format. We can also replace cadence formal tool with any other EDA formal tool in this flow. These flops are re-viewed with designer and forced to random value (0 or 1) during simulation. Using random initialization of the non resettable flops increases the probability of identifying

www.ijarcce.com



International Journal of Advanced Research in Computer and Communication Engineering Vol. 2, Issue 8, August 2013

**III. SOURCES OF X PROPAGATION IN GATE LEVEL** SIMULATION

X propagation can happen due to

### 1. Uninitialized memory array in the simulation.

Read transaction from a memory array which is not initialized causes X propagation in the design. All memories must be initialized during simulation. This can be easily done with compilation switch or doing out a back door loading of memory with all 0"s. For e.g. following compare is from VCS to initialize all memory arrays with 0's.

## +VCs+initmem+0|1

#### 2. Setup and hold violation

Setup and hold violation in SDF simulation may cause X propagation. This needs to be analyzed on a case by case basis and cross checked with STA reports if it is found in the same clock domain. Timing clean SDF should not have any setup or hold time violation for any flops in the same clock domain. If the violation appears on a flop which has a different clock domain as compare to originating flop then it should be checked if the violation is present on 1<sup>st</sup> flop of the two stage synchronizer, if yes, it can be ignored and Filter should be applied to mask such violation else synchronizer is required in such paths.

+notimingcheck or +no specify statements can be used to avoid X propagation from a known timing violation.

### 3. Un-initialized flops in the design

When hard reset of the design is asserted, all flops are supposed to have valid 0 or 1 value. Flop can be initialized by asynchronous set/clear pins or by synchronous reset 3.2 Synchronous reset flop without clock toggle during circuit. Figure 1 shows asynchronous resettable flop.

Asynchronous reset flops gets initialized to 0 or 1 as and when reset signal is asserted.



Figure 1: Asynchronous Resettable flop

In case of synchronous resettable flops - Figure 2, synchronous reset is applied to D input through combinational logic. It is ensured in design that before hard reset is removed, the flop gets initialized to valid value.



Figure 2: Synchronous Resettable flop

## 3.1 Un-initialized flops in the design

Non-resettable flops are the ones which do not have valid 0 or 1 value on Q of the flop during device reset assertion. These are the flops which cause 'X' propagation. These flops neither have set/clear pin nor synchronous reset provided. Identification of these flops is a critical task in GLS.

Unlike memories there is no simulator option which initializes all flops in the design. Simulator options are not effective in initializing UDPs in the design.

## reset phase

These are valid synchronous resettable flops. Reset is provided as combinatorial input to D. Clock to flop is disabled during reset assertion and no clock toggle happens during reset state. Though D input has valid 0 or 1 upon reset, Q will still hold value of 'X' after coming out of reset; clock may be enabled to this flop. By that time 'X' propagation happens to next flop in the design.

### 3.3 Flop with Combo loop back

As shown in Figure 3 and 4, these flops are mostly the flops whose D input is having a feedback path from the same non resettable flop or some other non resettable flop. These flops can never recover from 'X' after reset is removed.

Here NR stands for Non Resettable flop

![](_page_2_Picture_1.jpeg)

International Journal of Advanced Research in Computer and Communication Engineering Vol. 2, Issue 8, August 2013

![](_page_2_Figure_3.jpeg)

Figure 3: Non Resettable flop having feedback path from itself

![](_page_2_Figure_5.jpeg)

Figure 4: Non Resettable flop having feedback path from some other non resettable flop

During simulation any of the above 3 conditions originate 'X' and these 'X's are propagated through design'

### **IV. PROPOSED** METHODOLOGY

We have developed a standard automated flow which identifies all the required non resettable flops in the design which is must to initialize. This uses gate level VCD and a formal tool which first reads gate level net list and subsequently initializes its flop states from VCD at a given time point which is calculated from VCD at reset removal. Formal tool used here is cadence LEC verify. This flow is completed in 5 steps

Generate VCD of the fill design using zero delay 1. or SDF release and identify time point when reset is removed. This time point is T RR.

2. Invoke LEC verify

3. Read the same ZD/SDF design. LEC command used to read the design is "read design"

4. generated in 1<sup>st</sup> step, we need to specify the time at which resettable flops from design 2 which needs to be initialized states has to be initialized. This time point is T RR.

![](_page_2_Figure_16.jpeg)

Figure 5: flow diagram of the proposed methodology

Uninitialized flops listed in the last step are the flops which remains unknown at the time of reset removal and these are mainly the

Non resettable flops who is propagating 'X' due 1. to its D input is driven from feedback path from itself or some other non resettable path

Non resettable flop with valid D input but dead or 2. unknown clock.

Non resettable flops without set/clear pin and 3. without any synchronous reset.

Generate flop list can be reviewed with designer and initialized in gate level simulation with random values of 0 and 1 so that possible issues due to a particular initialization of these flop can be generated in GLS itself.

## V. RESULTS

The proposed scheme was successfully tested and proven on two SoC. We used Conformal LEC from Cadence Inc as formal tool and VCS as simulator to generate gate level VCD. Below table reports results from design 1 and design 2. As we can see that it finds 2464 number of non Initialize state of all the flops using VCD resettable flops from design 1 and 1548 number of non in GLS. Time required for running this flow is manageable.

![](_page_3_Picture_1.jpeg)

International Journal of Advanced Research in Computer and Communication Engineering Vol. 2, Issue 8, August 2013

| Table 1             |               |                 |
|---------------------|---------------|-----------------|
| Item                | Design 1      | Design 2        |
| Gate count          | ~ 180000000   | ~ 22000000      |
| Flop count          | 967534        | 1276390         |
|                     |               |                 |
| Gate level VCD      | 8 hours       | 10              |
| generation          | (including    | hours(including |
|                     | compile time) | compile time)   |
| Time taken be       | ~3 hours      | ~4 hours        |
| LEC in reading      |               |                 |
| net list            |               |                 |
| Time taken in       | ~35 minutes   | ~40 minutes     |
| initializing states |               |                 |
| from VCD            |               |                 |
| Time taken in       | ~15 minutes   | ~15 minutes     |
| reporting           |               |                 |
| uninitialized flops |               |                 |
| Non Resettable      | 2464          | 1548            |
| flops reported      |               |                 |

## **VI.** CONCLUSION

The proposed flow to generate list of un-initialized flops is very simple and fast. This can be used for fast gate level simulation bring up and to detect silicon bugs which remains undetected due to improper verification of non resettable flops.

### REFERENCES

[1] Anindya Saha and Rajendra S Ranmale , "using formal techniques for identifying uninitialized registers in soc designs"in ASIC/SOC Conference, 2002. 15th Annual IEEE International. Broadband Silicon Technology Center, Texas Instruments, Bangalore, India.

[2] Deepak Jindal and Mayank Digvijay Bindal. "Gaps and Challenges with Reset Logic Verifications." SNUG 2012

[3] Clifford E. Cummings, Sunburst Design, Inc. & Don Mills, LCDM Engineering. "Synchronous Resets? Asynchronous Resets?"

### BIOGRAPHIES

![](_page_3_Picture_11.jpeg)

Kamal Prakash Pandey is Associate Prof. SIET, Jhalwa–Allahabad. He obtained B.E. (Electronics and Communication Engg.) from MMMEC,Gorakhpur and M.Tech. from NIT Kurukshetra Haryana, fromerly

known as Regional Engg. College Kurukshetra Haryana His area of interest includes Antenna, VLSI, artificial neural network and integrated circuits he has published a book on integrated circuits.

![](_page_3_Picture_14.jpeg)

**Rakesh Kumar Singh** is Assistant Professor, Electronics and Communication Engg. SIET, Jhalwa, Allahabad. He has 7 years teaching experience. His area of interest includes Antenna, VLSI, Design and integrated circuits.

![](_page_3_Picture_16.jpeg)

**Dr. Anil Kumar** is Asst. Prof. SHIATS-DU Allahabad. He obtained B.E (MMMEC Gorakhpur) in ECE & M.Tech. (IIT BHU Formerly IT B.H.U.) in Microelectronics Engg. and Ph.D. from SHIATS-DU. He guided various projects & research at undergraduate &

postgraduate level. He published many research paper in different journals. He has more than 10 years teaching. experience and actively involved in research and publications. His area of interest includes Antenna, microwave, artificial neural network and VLSI.